Huge News!Announcing our $40M Series B led by Abstract Ventures.Learn More
Socket
Sign inDemoInstall
Socket

global-mercator

Package Overview
Dependencies
Maintainers
1
Versions
71
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

global-mercator

Tools to help with TMS, Quadkey & Google (XYZ) Tiles

  • 1.9.2
  • Source
  • npm
  • Socket score

Version published
Weekly downloads
967
decreased by-16.42%
Maintainers
1
Weekly downloads
 
Created
Source

Global Mercator

Build Status Coverage Status npm version MIT licensed

Standard - JavaScript Style Guide

A set of tools geospatial tools to help with TMS, Google (XYZ) Tiles.

This library is insipered by GDAL2Tiles, Google Summer of Code 2007 & 2008.

Another great simplistic tile library is tilebelt.

Install

npm

$ npm install --save global-mercator

web browser (ES6)

<script src="https://unpkg.com/global-mercator/global-mercator.min.js"></script>

Quickstart

var tile = [10, 15, 8] // [x, y, zoom]
mercator.tileToBBox(tile)
// [ -165.937, -82.853, -164.531, -82.676 ]

Features

FunctionDescription
lngLatToMeters(LngLat)Converts LngLat coordinates to Meters coordinates.
metersToLngLat(Meters)Converts Meters coordinates to LngLat coordinates.
metersToPixels(Meters, zoom)Converts Meters coordinates to Pixels coordinates.
lngLatToTile(LngLat, zoom)Converts LngLat coordinates to TMS Tile.
lngLatToGoogle(LngLat, zoom)Converts LngLat coordinates to Google (XYZ) Tile.
metersToTile(Meters, zoom)Converts Meters coordinates to TMS Tile.
pixelsToMeters(Pixels)Converts Pixels coordinates to Meters coordinates.
pixelsToTile(Pixels)Converts Pixels coordinates to TMS Tile.
tileToBBoxMeters(tile)Converts TMS Tile to bbox in Meters coordinates.
tileToBBox(tile)Converts TMS Tile to bbox in LngLat coordinates.
googleToBBoxMeters(google)Converts Google (XYZ) Tile to bbox in Meters coordinates.
googleToBBox(google)Converts Google (XYZ) Tile to bbox in LngLat coordinates.
tileToGoogle(tile)Converts TMS Tile to Google (XYZ) Tile.
googleToTile(google)Converts Google (XYZ) Tile to TMS Tile.
googleToQuadkey(google)Converts Google (XYZ) Tile to Quadkey.
tileToQuadkey(tile)Converts TMS Tile to QuadKey.
quadkeyToTile(quadkey)Converts Quadkey to TMS Tile.
quadkeyToGoogle(quadkey)Converts Quadkey to Google (XYZ) Tile.
bboxToMeters(bbox)Converts BBox from LngLat coordinates to Meters coordinates
grid(BBox, minZoom, maxZoom)Creates an Iterator of Tiles from a given BBox
gridBulk(BBox, minZoom, maxZoom, size)Creates a bulk Iterator of Tiles from a given BBox
gridLevels(BBox, minZoom, maxZoom)Creates a grid level pattern of arrays
gridCount(BBox, minZoom, maxZoom)Counts the total amount of tiles from a given BBox

API

hash

Hash for Map ID

Parameters

  • tile Tile [x, y, z]

Examples

const id = hash([312, 480, 4])
//=5728

Returns number hash

bboxToCenter

Converts BBox to Center

Parameters

  • bbox BBox [west, south, east, north] coordinates

Examples

const center = bboxToCenter([90, -45, 85, -50])
//= [ 87.5, -47.5 ]

Returns LngLat center

lngLatToMeters

Converts LngLat coordinates to Meters coordinates.

Parameters

  • lnglat LngLat Longitude (Meridians) & Latitude (Parallels) in decimal degrees

Examples

const meters = lngLatToMeters([126, 37])
//=[ 14026255.8, 4439106.7 ]

Returns Meters Meters coordinates

metersToLngLat

Converts Meters coordinates to LngLat coordinates.

Parameters

  • meters Meters Meters in Mercator [x, y]

Examples

const lnglat = metersToLngLat([14026255, 4439106])
//=[ 126, 37 ]

Returns LngLat LngLat coordinates

metersToPixels

Converts Meters coordinates to Pixels coordinates.

Parameters

  • meters Meters Meters in Mercator [x, y]
  • zoom number Zoom level

Examples

const pixels = metersToPixels([14026255, 4439106], 13)
//=[ 1782579.1, 1280877.3, 13 ]

Returns Pixels Pixels coordinates

lngLatToTile

Converts LngLat coordinates to TMS Tile.

Parameters

  • lnglat LngLat Longitude (Meridians) & Latitude (Parallels) in decimal degrees
  • zoom number Zoom level

Examples

const tile = lngLatToTile([126, 37], 13)
//=[ 6963, 5003, 13 ]

Returns Tile TMS Tile

lngLatToGoogle

Converts LngLat coordinates to Google (XYZ) Tile.

Parameters

  • lnglat LngLat Longitude (Meridians) & Latitude (Parallels) in decimal degrees
  • zoom number Zoom level

Examples

const google = lngLatToGoogle([126, 37], 13)
//=[ 6963, 3188, 13 ]

Returns Google Google (XYZ) Tile

metersToTile

Converts Meters coordinates to TMS Tile.

Parameters

  • meters Meters Meters in Mercator [x, y]
  • zoom number Zoom level

Examples

const tile = metersToTile([14026255, 4439106], 13)
//=[ 6963, 5003, 13 ]

Returns Tile TMS Tile

pixelsToMeters

Converts Pixels coordinates to Meters coordinates.

Parameters

  • pixels Pixels Pixels [x, y, zoom]

Examples

const meters = pixelsToMeters([1782579, 1280877, 13])
//=[ 14026252.0, 4439099.5 ]

Returns Meters Meters coordinates

pixelsToTile

Converts Pixels coordinates to TMS Tile.

Parameters

  • pixels Pixels Pixels [x, y, zoom]

Examples

const tile = pixelsToTile([1782579, 1280877, 13])
//=[ 6963, 5003, 13 ]

Returns Tile TMS Tile

tileToBBoxMeters

Converts TMS Tile to bbox in Meters coordinates.

Parameters

Examples

const bbox = tileToBBoxMeters([6963, 5003, 13])
//=[ 14025277.4, 4437016.6, 14030169.4, 4441908.5 ]

Returns BBox bbox extent in [minX, minY, maxX, maxY] order

tileToBBox

Converts TMS Tile to bbox in LngLat coordinates.

Parameters

Examples

const bbox = tileToBBox([6963, 5003, 13])
//=[ 125.991, 36.985, 126.035, 37.020 ]

Returns BBox bbox extent in [minX, minY, maxX, maxY] order

googleToBBoxMeters

Converts Google (XYZ) Tile to bbox in Meters coordinates.

Parameters

  • google Google Google [x, y, zoom]

Examples

const bbox = googleToBBoxMeters([6963, 3188, 13])
//=[ 14025277.4, 4437016.6, 14030169.4, 4441908.5 ]

Returns BBox bbox extent in [minX, minY, maxX, maxY] order

googleToBBox

Converts Google (XYZ) Tile to bbox in LngLat coordinates.

Parameters

  • google Google Google [x, y, zoom]

Examples

const bbox = googleToBBox([6963, 3188, 13])
//=[ 125.991, 36.985, 126.035, 37.020 ]

Returns BBox bbox extent in [minX, minY, maxX, maxY] order

tileToGoogle

Converts TMS Tile to Google (XYZ) Tile.

Parameters

  • tile Tile Tile [x, y, zoom]

Examples

const google = tileToGoogle([6963, 5003, 13])
//=[ 6963, 3188, 13 ]

Returns Google Google (XYZ) Tile

googleToTile

Converts Google (XYZ) Tile to TMS Tile.

Parameters

  • google Google Google [x, y, zoom]

Examples

const tile = googleToTile([6963, 3188, 13])
//=[ 6963, 5003, 13 ]

Returns Tile TMS Tile

googleToQuadkey

Converts Google (XYZ) Tile to Quadkey.

Parameters

  • google Google Google [x, y, zoom]

Examples

const quadkey = googleToQuadkey([6963, 3188, 13])
//='1321102330211'

Returns string Microsoft's Quadkey schema

tileToQuadkey

Converts TMS Tile to QuadKey.

Parameters

  • tile Tile Tile [x, y, zoom]

Examples

const quadkey = tileToQuadkey([6963, 5003, 13])
//='1321102330211'

Returns string Microsoft's Quadkey schema

quadkeyToTile

Converts Quadkey to TMS Tile.

Parameters

  • quadkey string Microsoft's Quadkey schema

Examples

const tile = quadkeyToTile('1321102330211')
//=[ 6963, 5003, 13 ]

Returns Tile TMS Tile

quadkeyToGoogle

Converts Quadkey to Google (XYZ) Tile.

Parameters

  • quadkey string Microsoft's Quadkey schema

Examples

const google = quadkeyToGoogle('1321102330211')
//=[ 6963, 3188, 13 ]

Returns Google Google (XYZ) Tile

bboxToMeters

Converts BBox from LngLat coordinates to Meters coordinates

Parameters

  • bbox BBox extent in [minX, minY, maxX, maxY] order

Examples

const meters = bboxToMeters([ 125, 35, 127, 37 ])
//=[ 13914936.3, 4163881.1, 14137575.3, 4439106.7 ]

Returns BBox bbox extent in [minX, minY, maxX, maxY] order

grid

Creates an Iterator of Tiles from a given BBox

Parameters

  • bbox BBox extent in [minX, minY, maxX, maxY] order
  • minZoom number Minimum Zoom
  • maxZoom number Maximum Zoom

Examples

const iterable = grid([-180.0, -90.0, 180, 90], 3, 8)
const {value, done} = iterable.next()
//=value
//=done

Returns Iterator<Tile> Iterable Tiles from BBox

gridBulk

Creates a bulk Iterator of Tiles from a given BBox

Parameters

  • bbox BBox extent in [minX, minY, maxX, maxY] order
  • minZoom number Minimum Zoom
  • maxZoom number Maximum Zoom
  • size number Maximum size for bulk Tiles

Examples

const grid = gridBulk([-180.0, -90.0, 180, 90], 3, 8, 5000)
const {value, done} = grid.next()
//=value
//=done

Returns Iterator<Array<Tile>> Bulk iterable Tiles from BBox

gridLevels

Creates a grid level pattern of arrays

Parameters

  • bbox BBox extent in [minX, minY, maxX, maxY] order
  • minZoom number Minimum Zoom
  • maxZoom number Maximum Zoom

Examples

const levels = gridLevels([-180.0, -90.0, 180, 90], 3, 8)
//=levels

Returns Array<GridLevel> Grid Level

gridCount

Counts the total amount of tiles from a given BBox

Parameters

  • bbox BBox extent in [minX, minY, maxX, maxY] order
  • minZoom number Minimum Zoom
  • maxZoom number Maximum Zoom

Examples

const count = gridCount([-180.0, -90.0, 180, 90], 3, 8)
//=563136

Returns number Total tiles from BBox

validateTile

Validates TMS Tile.

Parameters

  • tile Tile Tile [x, y, zoom]

Examples

validateTile([60, 80, 12])
//=[60, 80, 12]
validateTile([60, -43, 5])
//= Error: Tile <y> must not be less than 0
validateTile([25, 60, 3])
//= Error: Illegal parameters for tile
  • Throws Error Will throw an error if TMS Tile is not valid.

Returns Tile TMS Tile

validateZoom

Validates Zoom level.

Parameters

Examples

mercator.validateZoom(12)
//=12
mercator.validateZoom(-4)
//= Error: <zoom> cannot be less than 0
validateZoom(32)
//= Error: <zoom> cannot be greater than 30
  • Throws Error Will throw an error if zoom is not valid.

Returns number zoom Zoom level

validateLngLat

Validates LngLat coordinates.

Parameters

  • lnglat LngLat Longitude (Meridians) & Latitude (Parallels) in decimal degrees

Examples

validateLngLat([-115, 44])
//= [ -115, 44 ]
validateLngLat([-225, 44])
//= Error: LngLat [lng] must be within -180 to 180 degrees
  • Throws Error Will throw an error if LngLat is not valid.

Returns LngLat LngLat coordinates

validatePixels

Validates Pixels coordinates.

Parameters

  • pixels Pixels Pixels [x, y, zoom]
  • x number Pixels X
  • y number Pixels Y
  • zoom number? Zoom level

Examples

validatePixels([-115, 44])
  • Throws Error Will throw an error if Pixels is not valid.

Returns Pixels Pixels coordinates

Keywords

FAQs

Package last updated on 17 Feb 2017

Did you know?

Socket

Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.

Install

Related posts

SocketSocket SOC 2 Logo

Product

  • Package Alerts
  • Integrations
  • Docs
  • Pricing
  • FAQ
  • Roadmap
  • Changelog

Packages

npm

Stay in touch

Get open source security insights delivered straight into your inbox.


  • Terms
  • Privacy
  • Security

Made with ⚡️ by Socket Inc